/*
 * Copyright 2016, Simula Research Laboratory
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 */
#pragma once

#ifndef INF
#define INF               (1<<29)
#endif
#ifndef NINF
#define NINF              (-INF)
#endif
#ifdef M_PI
#undef M_PI
// #define M_PI  3.14159265358979323846f
#endif
__device__ static const
float M_PI = 3.14159265358979323846f;
#ifdef M_PI2
#undef M_PI2
// #define M_PI2 (2.0F * M_PI)
#endif
__device__ static const
float M_PI2 = 2.0f * 3.14159265358979323846f;

#define M_4RPI               (4.0f / M_PI)

#define DESC_MIN_FLOAT               1E-15F

// #define GAUSS_ALIGN  16
#define GAUSS_ALIGN  32
#define GAUSS_LEVELS 12

#define ORI_V1_NUM_THREADS 16
#define ORI_NBINS          36
#define ORI_WINFACTOR      1.5F

#define DESC_BINS          8
#define DESC_MAGNIFY       3.0f

// Lowe wants at most 3 orientations at every extremum,
// VLFeat uses at most 4
#undef  LOWE_ORIENTATION_MAX

#ifdef LOWE_ORIENTATION_MAX
#define ORIENTATION_MAX_COUNT 3
#else
#define ORIENTATION_MAX_COUNT 4
#endif

namespace popsift {

struct ConstInfo
{
    int   max_extrema;
    int   max_orientations;
    float sigma0;
    float sigma_k;
    float edge_limit;
    float threshold;
    int   norm_multi;
    float desc_gauss[40][40];
    float desc_tile[16];
};

extern                         ConstInfo h_consts;
extern __device__ __constant__ ConstInfo d_consts;


void init_constants( float sigma0, int levels, float threshold, float edge_limit, int max_extrema, int normalization_multiplier );

} // namespace popsift

